# Copyright 2019 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

# NOTE: This file is auto generated by the elixir code generator program.
# Do not edit this file manually.

defmodule GoogleApi.Dataproc.V1.Model.ResizeNodeGroupRequest do
  @moduledoc """
  A request to resize a node group.

  ## Attributes

  *   `gracefulDecommissionTimeout` (*type:* `String.t`, *default:* `nil`) - Optional. Timeout for graceful YARN decommissioning. Graceful decommissioning (https://cloud.google.com/dataproc/docs/concepts/configuring-clusters/scaling-clusters#graceful_decommissioning) allows the removal of nodes from the Compute Engine node group without interrupting jobs in progress. This timeout specifies how long to wait for jobs in progress to finish before forcefully removing nodes (and potentially interrupting jobs). Default timeout is 0 (for forceful decommission), and the maximum allowed timeout is 1 day. (see JSON representation of Duration (https://developers.google.com/protocol-buffers/docs/proto3#json)).Only supported on Dataproc image versions 1.2 and higher.
  *   `parentOperationId` (*type:* `String.t`, *default:* `nil`) - Optional. operation id of the parent operation sending the resize request
  *   `requestId` (*type:* `String.t`, *default:* `nil`) - Optional. A unique ID used to identify the request. If the server receives two ResizeNodeGroupRequest (https://cloud.google.com/dataproc/docs/reference/rpc/google.cloud.dataproc.v1#google.cloud.dataproc.v1.ResizeNodeGroupRequests) with the same ID, the second request is ignored and the first google.longrunning.Operation created and stored in the backend is returned.Recommendation: Set this value to a UUID (https://en.wikipedia.org/wiki/Universally_unique_identifier).The ID must contain only letters (a-z, A-Z), numbers (0-9), underscores (_), and hyphens (-). The maximum length is 40 characters.
  *   `size` (*type:* `integer()`, *default:* `nil`) - Required. The number of running instances for the node group to maintain. The group adds or removes instances to maintain the number of instances specified by this parameter.
  """

  use GoogleApi.Gax.ModelBase

  @type t :: %__MODULE__{
          :gracefulDecommissionTimeout => String.t() | nil,
          :parentOperationId => String.t() | nil,
          :requestId => String.t() | nil,
          :size => integer() | nil
        }

  field(:gracefulDecommissionTimeout)
  field(:parentOperationId)
  field(:requestId)
  field(:size)
end

defimpl Poison.Decoder, for: GoogleApi.Dataproc.V1.Model.ResizeNodeGroupRequest do
  def decode(value, options) do
    GoogleApi.Dataproc.V1.Model.ResizeNodeGroupRequest.decode(value, options)
  end
end

defimpl Poison.Encoder, for: GoogleApi.Dataproc.V1.Model.ResizeNodeGroupRequest do
  def encode(value, options) do
    GoogleApi.Gax.ModelBase.encode(value, options)
  end
end
